package com.ophiux.wechat.model;

/**
 * 微信公众号支付-普通商户-统一下单请求实体
 * @author chenh
 *除被扫支付场景以外，商户系统先调用该接口在微信支付服务后台生成预支付交易单，
 *返回正确的预支付交易回话标识后再按扫码、JSAPI、APP等不同场景生成交易串调起支付。
 */
public class BaseUnifiedOrderRequest {

	/**
	 * 公众账号ID
	 * 必填
	 * 微信分配的公众账号ID（企业号corpid即为此appId）
	 */
	private String appid;
	
	/**
	 * 商户号
	 * 必填
	 * 微信支付分配的商户号
	 */
	private String mch_id;
	
	/**
	 * 设备号
	 * 非必填
	 * 终端设备号(门店号或收银设备ID)，注意：PC网页或公众号内支付请传"WEB"
	 */
	private String device_info;
	
	/**
	 * 随机字符串
	 * 必填
	 * 随机字符串，不长于32位。推荐随机数生成算法
	 */
	private String nonce_str;
	
	/**
	 *签名
	 * 必填
	 * 签名，详见签名生成算法
	 */
	private String sign;
	
	/**
	 *签名类型
	 * 非必填
	 * 签名类型，目前支持HMAC-SHA256和MD5，默认为MD5
	 */
	private String sign_type;
	
	/**
	 *商品描述
	 * 必填
	 * 商品简单描述，该字段须严格按照规范传递，具体请见参数规定
	 */
	private String body;
	
	/**
	 *商品详情
	 * 非必填
	 * 商品详细列表，使用Json格式，传输签名前请务必使用CDATA标签将JSON文本串保护起来。
		goods_detail []：
		└ goods_id String 必填 32 商品的编号
		└ wxpay_goods_id String 可选 32 微信支付定义的统一商品编号
		└ goods_name String 必填 256 商品名称
		└ quantity Int 必填 商品数量
		└ price Int 必填 商品单价，单位为分
		└ goods_category String 可选 32 商品类目ID
		└ body String 可选 1000 商品描述信息
	 */
	private String detail;
	
	/**
	 *附加数据
	 * 非必填
	 * 附加数据，在查询API和支付通知中原样返回，该字段主要用于商户携带订单的自定义数据
	 */
	private String attach;
	
	/**
	 *商户订单号
	 * 必填
	 * 商户系统内部的订单号,32个字符内、可包含字母, 其他说明见商户订单号
	 */
	private String out_trade_no;
	
	/**
	 *货币类型
	 * 非必填
	 * 符合ISO 4217标准的三位字母代码，默认人民币：CNY，其他值列表详见货币类型
	 */
	private String fee_type;
	
	/**
	 *总金额
	 * 必填
	 * 订单总金额，单位为分，详见支付金额
	 */
	private String total_fee;
	
	/**
	 *终端IP
	 * 必填
	 * APP和网页支付提交用户端ip，Native支付填调用微信支付API的机器IP。
	 */
	private String spbill_create_ip;
	
	/**
	 *交易起始时间
	 * 非必填
	 *订单生成时间，格式为yyyyMMddHHmmss，如2009年12月25日9点10分10秒表示为20091225091010。其他详见时间规则
	 */
	private String 	time_start;
	
	/**
	 *交易结束时间
	 * 非必填
	 * 订单失效时间，格式为yyyyMMddHHmmss，如2009年12月27日9点10分10秒表示为20091227091010。其他详见时间规则
			注意：最短失效时间间隔必须大于5分钟
	 */
	private String 	time_expire;
	
	/**
	 *商品标记
	 * 非必填
	 * 商品标记，代金券或立减优惠功能的参数，说明详见代金券或立减优惠
	 */
	private String goods_tag;
	
	/**
	 *通知地址
	 * 必填
	 * 接收微信支付异步通知回调地址，通知url必须为直接可访问的url，不能携带参数。
	 */
	private String notify_url;
	
	/**
	 *交易类型
	 *  必填
	 * 取值如下：JSAPI，NATIVE，APP，详细说明见参数规定
	 */
	private String trade_type;
	
	/**
	 *商品ID
	 *  必填
	 * trade_type=NATIVE，此参数必传。此id为二维码中包含的商品ID，商户自行定义。
	 */
	private String product_id;
	
	/**
	 *指定支付方式
	 *  非必填
	 * no_credit--指定不能使用信用卡支付
	 */
	private String limit_pay;
	
	/**
	 *用户标识
	 *  必填
	 * trade_type=JSAPI，此参数必传，用户在商户appid下的唯一标识。openid如何获取，可参考【获取openid】。
	 * 企业号请使用【企业号OAuth2.0接口】获取企业号内成员userid，再调用【企业号userid转openid接口】进行转换
	 */
	private String openid;

	public String getAppid() {
		return appid;
	}

	public void setAppid(String appid) {
		this.appid = appid;
	}

	public String getMch_id() {
		return mch_id;
	}

	public void setMch_id(String mch_id) {
		this.mch_id = mch_id;
	}

	public String getDevice_info() {
		return device_info;
	}

	public void setDevice_info(String device_info) {
		this.device_info = device_info;
	}

	public String getNonce_str() {
		return nonce_str;
	}

	public void setNonce_str(String nonce_str) {
		this.nonce_str = nonce_str;
	}

	public String getSign() {
		return sign;
	}

	public void setSign(String sign) {
		this.sign = sign;
	}

	public String getSign_type() {
		return sign_type;
	}

	public void setSign_type(String sign_type) {
		this.sign_type = sign_type;
	}

	public String getBody() {
		return body;
	}

	public void setBody(String body) {
		this.body = body;
	}

	public String getDetail() {
		return detail;
	}

	public void setDetail(String detail) {
		this.detail = detail;
	}

	public String getAttach() {
		return attach;
	}

	public void setAttach(String attach) {
		this.attach = attach;
	}

	public String getOut_trade_no() {
		return out_trade_no;
	}

	public void setOut_trade_no(String out_trade_no) {
		this.out_trade_no = out_trade_no;
	}

	public String getFee_type() {
		return fee_type;
	}

	public void setFee_type(String fee_type) {
		this.fee_type = fee_type;
	}

	public String getTotal_fee() {
		return total_fee;
	}

	public void setTotal_fee(String total_fee) {
		this.total_fee = total_fee;
	}

	public String getSpbill_create_ip() {
		return spbill_create_ip;
	}

	public void setSpbill_create_ip(String spbill_create_ip) {
		this.spbill_create_ip = spbill_create_ip;
	}

	public String getTime_start() {
		return time_start;
	}

	public void setTime_start(String time_start) {
		this.time_start = time_start;
	}

	public String getTime_expire() {
		return time_expire;
	}

	public void setTime_expire(String time_expire) {
		this.time_expire = time_expire;
	}

	public String getGoods_tag() {
		return goods_tag;
	}

	public void setGoods_tag(String goods_tag) {
		this.goods_tag = goods_tag;
	}

	public String getNotify_url() {
		return notify_url;
	}

	public void setNotify_url(String notify_url) {
		this.notify_url = notify_url;
	}

	public String getTrade_type() {
		return trade_type;
	}

	public void setTrade_type(String trade_type) {
		this.trade_type = trade_type;
	}

	public String getProduct_id() {
		return product_id;
	}

	public void setProduct_id(String product_id) {
		this.product_id = product_id;
	}

	public String getLimit_pay() {
		return limit_pay;
	}

	public void setLimit_pay(String limit_pay) {
		this.limit_pay = limit_pay;
	}

	public String getOpenid() {
		return openid;
	}

	public void setOpenid(String openid) {
		this.openid = openid;
	}
	
	
}
